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(54) Method for file transfer 

(57) A method is provided of downloading a file from 
an Internet server 12 to an Internet client 10, preferably 
without action by the Internet client. The method begins 
by associating the file into a set of components at the 
server. A profile of the file is then generated. This profile 
includes identifying information for the file as well as for 
each component thereof. Such information preferably 
includes an identifier, a size value, and a code uniquely 
identifying the component. The file is transferred by in- 


itiating a download sequence by which each component 
is transferred, one-by-one, from the server to the client 
using an Internet protocol. When the download se- 
quence is complete, the individual components are re- 
assembled into the file using the profile without action 
by the Internet client. If the transmission is interrupted 
for any reason, the download sequence is restarted with 
the component affected by the interruption. This avoids 
the need to retransfer the entire file. 
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Description 

The present invention relates generally to computer 
networks and more particularly to the efficient transfer 
of relatively large computer files over the Internet using 
standard Internet protocols. 

The Internet offers a suite of well-known services 
including one-to-one messaging (e-mail), one-to-many 
messaging (bulletin board), on-line chat, file transfer 
and browsing. Various known Internet protocols are 
used for these services. Thus, for example, browsing is 
effected using the Hypertext Transfer Protocol (HTTP), 
which provides users access to multimedia files using 
Hypertext Markup Language (HTML). The collection of 
servers that use HTTP comprise the World Wide Web, 
which is the Internet's multimedia information retrieval 
system. The File Transfer Protocol (FTP) is a mecha- 
nism for transferring files from a server to a client. Typ- 
ically, the client includes an FTP interlace and appropri- 
ate software to control transfer and decompression of 
the received file. 

There has been great interest in providing Internet 
access at minimal economic cost. While most comput- 
ers now are pre-configured for Internet access, a signif- 
icant percentage of households still do not have a per- 
sonal computer. Thus, it has now been proposed to pro- 
vide a data processing system that, much like a VCR, 
may be connected to a television set and used in lieu of 
a personal computer to provide Web access through a 
conventional remote control device associated with the 
system unit. Such a system enables the television to be- 
come, in effect, a "Web" appliance. The viewer can rap- 
idly switch between conventional television and Internet 
access using the remote control unit. All of the conven- 
tional "Internet" access tools and navigational functions 
are preferably "built-in" to the system and thus hidden 
to the user. 

It would also be desirable to update software run- 
ning on the Web appliance without interaction or even 
the knowledge of the user. This goal, however, cannot 
be achieved reliably and cheaply because FTP and oth- 
er Internet protocols do not allow file transfer restarts. A 
file transfer "restart" means that the transfer is re-initiat- 
ed at a point of interruption. Thus, in the event that a 
conventional FTP file transmission were interrupted, e. 
g., due to a power outage or other such event, it is nec- 
essary to retransfer the entire file. This is highly imprac- 
tical with very large files across a typical 28.8Kbs mo- 
dem, especially without user interaction. 

Accordingly the present invention provides a meth- 
od of downloading a file comprising a set of components 
from a server to a client over a network, comprising the 
steps of: 

generating a profile of the file that includes identify- 
ing information for each component; 
initiating a download sequence by which each com- 
ponent is transferred, one-by-one, from the server 


to the clieni using a network transmission protocol; 
when the download sequence is complete, reas- 
sembling the components into the file using the pror 
file. 

5 

In the preferred embodiment, the method further 
comprises the step of restarting the download se- 
quence, following interruption of the download se- 
quence, with a component affected by the interruption, 

10 wherein any component transferred prior to the interrup- 
tion is not re-transferred from the server to the client, 
thereby improving overall transmission efficiency. The 
network transmission protocol is preferably the File 
Transfer Protocol (FTP), but any other suitable existing 

15 or future protocol could be used. The identifying infor- 
mation in the profile for each component includes an 
identifier, a value indicating the size of the component, 
and a code uniquely identifying the component, with the 
code preferably being a cyclic redundancy code. This 

20 allows verification that a component transferred to the 
client is part of the file using the identifying information. 

Further in the preferred embodiment, there is an in- 
itial step of breaking the file into the set of components, 
followed by transferring the profile from the server to the 

25 client prior to initiating the download sequence. The pro- 
file includes identifying information for the file (prefera- 
bly including a code uniquely identifying the file) and 
each component thereof, and the method further com- 
prises the steps of: using the identifying information up- 

30 on receipt at the client of a component to verify whether 
a complete version of the component has been trans- 
ferred; if the complete version of the component has not 
been transferred, restarting the download sequence 
with the component; and when the download sequence 

35 is complete, verifying whether a complete version of the 
file has been transferred using the identifying informa- 
tion for the file; and if the complete version of the file has 
been transferred, reassembling the components into the 
file. Typically the profile will be re-transferred from the 

40 server to the client prior to restarting the download se- 
quence. It is preferred that the components are trans- 
ferred in a sequential order as determined by the profile, 
although this is not required, since they can be properly 
ordered at the client during the reassembly process. 

45 in one preferred embodiment, the network is the In- 
ternet, the client is a Web appliance attached to the In- 
ternet, and the file is a updated version of a program 
running on the Web appliance. Preferably the file is 
downloaded overthe Internet to the Web appliance with- 

50 out requiring any specific action by a user (in other 
words, the file update occurs automatically, transparent- 
ly to the user). 

The invention further provides a computer program 
product for use in downloading a file, comprising a set 

55 of components, from a server to a client, the computer 
program product comprising: 

a computer-readable storage medium having a 
substrate; and a program encoded in the substrate of 
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the computer-readable storage medium, wherein the 
program includes means for performing the file down- 
load methods described above. 

The invention further provides a client computer 
connectabletothe Internet, comprising: a processor; an 
operating system; Internet protocol means; and a client 
component of a file transfer download routine, the client 
component having an associated server component 
supported on a server; wherein the client component of 
the file transfer download routine includes means re- 
sponsive to receipt of component pieces of a file for re- 
assembling component pieces into the file using a file 
profile. Such a client computer can be integrated for ex- 
ample as a base unit into a data processing system in- 
cluding a remote control unit and a monitor. 

In complementary fashion the invention further pro- 
vides a server computer connectable to the Internet, 
comprising: a processor; an operating system; Internet 
protocol means; and a server component of a file trans- 
fer download routine, the server component having an 
associated client component supported on a client ma- 
chine; wherein the server component includes means 
for initiating a download sequence by which compo- 
nents of afile are transferred, one-by-one, from the serv- 
er computer to the client machine using the Internet pro- 
tocol means, and means responsive to any interruption 
of the download sequence for restarting the sequence 
with the component affected by the interruption.. 

Viewed from another aspect, the invention provides 
a computer program product for use in downloading a 
file, consisting of a set of components, from a Internet 
server to an Internet client, the computer program prod- 
uct comprising: 

a computer-readable storage medium having a sub- 
strate; and 

program data encoded in the substrate of the com- 
puter-readable storage medium, wherein the pro- 
gram data comprises: means for generating a pro- 
file that includes identifying information for the file 
and for each component thereof; means for initiat- 
ing a download sequence by which each compo- 
nent is transferred, one-by-one, from the server to 
the client using an Internet protocol; means respon- 
sive to any interruption of the download sequence, 
for restarting the download sequence with the com- 
ponent affected by the interruption; and means re- 
sponsive to completion of the download sequence 
for reassembling the components into the file using 
the profile. 

Viewed from a further aspect, the invention also pro- 
vides a computer program product for use in download- 
ing a file from a Internet server to an Internet client, the 
computer program product comprising: 

a computer-readable storage medium having a sub- 
strate; and 


program data encoded in the substrate of the com: 
puter-readable storage medium, wherein the pro- 
gram data comprises: means for breaking the file 
into a set of components; means for generating a 

5 profile that includes identifying information for the 
file and for each component thereof; means for 
transferring the profile from the server to the client; 
means for initiating a download sequence accord- 
ing to the profile by which each component is trans- 

10 ferred, one-by-one, from the server to the client us- 
ing an Internet protocol; means responsive to any 
interruption of the download, sequence for retrans- 
ferring the profile from the server to the client and 
restarting the download sequence with the compo- 

15 nent affected by the interruption; and means re- 
sponsive to completion of the download sequence 
for reassembling the components into the file using 
the retransferred profile. 

20 Viewed from a still further aspect, the invention also 
provides a method of downloading a file, consisting of 
a set of components, from a Internet server to an Inter- 
net client, comprising the steps of: 

25 generating a profile of the file that includes identify- 
ing information for each component; 
initiating a download sequence by which each com- 
ponent is transferred, one-by-one, from the server 
to the client using an Internet protocol; 

30 when the .download sequence is complete, reas- 
sembling the components into the file using the pro- 
file. 

Viewed from a still further aspect, the invention also 
35 provides a method of downloading a file, consisting of 
a set of components, from an Internet server to an In- 
ternet client, the file represented by a profile that in- 
cludes identifying information for the file and for each 
component thereof, comprising the steps of: 

40 

initiating a download sequence according to the 
profile by which each component is transferred, 
one-by-one, from the server to the client using the 
Internet File Transfer Protocol (FTP); 

45 upon receipt at the client of a component, using the 
identifying information to verify whether a complete 
version of the component has been transferred; 
if the complete version of the component has not 
been transferred, restarting the download se- 

50 quence with the component; and 

when the download sequence is complete, verifying 
whether a complete version of the file has been 
transferred using the identifying information for the 
file; 

55 if the complete version of the file has been trans- 
ferred, reassembling the components into the file. 

The file transfer mechanism of the invention allows 
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conventional FTP but at the same time allows for file 
transfer restarts. This effectively provides a checkpoint- 
able method for downloading files across the Internet or 
other suitable network. This therefore represents a 
method for downloading a file without a proprietary pro- 
tocol but which still allows for file transfer restarts in the 
event of transmission interruption. One application of 
this mechanism is to update software running on a Web 
appliance transparently to the user by downloading a 
file from an Internet server to the appliance, thereby en- 
hancing the ease with which software is downloaded 
over the Internet. Such a file transfer download over the 
Internet would repeatedly transfer a discrete piece of a 
file as an atomic operation and then reassemble the dis- 
crete pieces at the client (preferably without direct user 
intervention). 

As described above, a file can be downloaded from 
an Internet server to an Internet client, preferably with- 
out interaction by a user of the Internet client, starting 
by breaking the file into a set of components. Then, a 
profile is generated for the file that includes identifying 
information for the file and for each component thereof. 
The identifying information may include an identifier, a 
size value, and a code uniquely identifying the file and/ 
or component thereof. To transfer the. file, a download 
sequence is initiated by which each component is trans- 
ferred, one-by-one, from the server to the client. Prefer- 
ably, the transfer of each component is achieved using 
conventional Internet FTP. When the download se- 
quence is complete, the components are reassembled. 
If the download sequence were interrupted for any rea- 
son, it is restarted at the point of interruption, as opposed 
to requiring retransmission of previously-delivered com- 
ponents. Preferably, the components of the file are 
transferred in a sequential order as determined by the 
profile. 

Preferably, the file profile is transmitted from the 
server to the client prior to initiation and, if necessary, 
any restart(s) of the download sequence. The profile is 
then used to verify whether components received at the 
client are "complete. 0 Thus, for example, upon receipt 
at the client of a component, the identifying information 
is used to verify whether a complete version of the com- 
ponent has been transferred from the server.-Typically, 
this is accomplished by comparing the size of the com- 
ponent with the expected size (as determined by the 
size value in the profile) and by calculating the code and 
comparing it to the code in the profile. If the complete 
version of the component has not been transferred (as 
determined by one or both of these tests), the profile is 
resent and the download sequence is restarted, begin- 
ning with the component whose transmission was in- 
complete. When the server completes the download, 
the client-resident code verifies whether a complete ver- 
sion of the file has been transferred using the identifying 
information for the file. If the complete version of the file 
has been transferred, the components thereof are then 
reassembled into the file. 


In the preferred embodiment, the Internet client is 
a Web appliance and the file is a updated version of a 
program (e.g., a browser) running on the Web appli- 
ance. 

Various embodiments of the invention will now be 
described in detail by way of example only with refer- 
ence to the following drawings: 

FIGURE 1 is a representative client-server system 
for communication over the Internet; 
FIGURE 2A is pictorial representation of a data 
processing system unit connected to a conventional 
television set to form a "Web" appliance; 
FIGURE 2B is a pictorial representation of a front 
panel of the data processing system unit; 
FIGURE 2C is a pictoriaf representation of a rear 
panel of the data processing system unit; 
FIGURE 2D is a pictorial representation of a remote 
control unit associated with the data processing 
system unit; 

FIGURE 3 is a block diagram of the major compo- 
nents of the data processing system unit; 
FIGURE 4 is a process flow diagram of a preferred 
method for downloading a file from an Internet serv- 
er to an Internet client such as the Web appliance 
of FIGURE 2A; 

FIGURE 5 is a representative file "profile"; and 
FIGURE 6 is a flowchart of the preferred method. 

FIGURE 1 illustrates an Internet client machine 10 
connected to a server platform 12 via a communication 
channel 14. For illustrative purposes, channel 14 is the 
Internet, an Intranet or other known connection. In the 
case of the Internet, server platform 12 is one of a plu- 
rality of servers which are accessible by clients, one of 
which is illustrated by machine 1 0. A client machine typ- 
ically includes a suite of known Internet tools to access 
the.servers of the network and thus obtain certain serv- 
ices. These services include one-to-one messaging (e- 
mail), one-to-many messaging (bulletin board), on-line 
chat, file transfer and browsing. Various known Internet 
protocols are used for these services. Thus, for exam- 
ple, browsing is effected using the Hypertext Transfer 
Protocol (HTTP), which provides users access to multi- 
media files using Hypertext Markup Language (HTML). 
The collection of servers that use HTTP comprise the 
World Wide Web, which is the Internet's multimedia in- 
formation retrieval system. The File Transfer Protocol 
(FTP) is a mechanism for transferring files from a server 
to a client. Typically, the client includes an FTP interface 
and associated code to facilitate the transfer and, if 
needed, decompression of the received file/Appropriate 
code is also resident on the server side of a particular 
connection (at a so-called "FTP site"). 

By way of example only, a client machine is a per- 
sonal computer such as a desktop or notebook compu- 
ter, e.g., an IBM or IBM-compatible machine running un- 
der the OS/2 operating system, an IBM ThinkPad ma- 
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chine, or some other Intel x86 or Pentium-based com- 
puter running Windows 3. 1 or greater operating system; 
a representative server platform 12 comprises an IBM 
RS/6000 computer 18 (a RISC-based workstation) run- 
ning the AIX operating system 20 (version 4.1 or above) 
and a server program 22. (IBM, OS/2, Thinkpad, RS/ 
6000, and AIX are trademarks of IBM Corporation; Intel 
and Pentium are trademarks of Intel Corporation; Win- 
dows is a trademark of Microsoft Corporation). In a pre- 
ferred embodiment, the server program 22 supports 
FTP in a known manner, using FTP mechanism 23 and 
thus the server platform is an FTP site. FTP is a TCP/ 
IP protocol for file transfers. Information about the FTP 
protocol may be obtained from Request For Comment 
(RFC) 765 (Oct. 1985), which is incorporated herein by 
reference. The platform 1 2 also includes a graphical us- 
er interface (GUI) 24 for management and administra- 
tion. It may also include an application programming in- 
terface (API). The various models of the RS/6000 com- 
puters are described in many publications of the IBM 
Corporation, for example, RISC System/6000, 7013and 
7016 POWERstation and POWERserver Hardware 
Technical Reference, Order No. SA23-2644-00, whilst 
the AIX operating system is described in AIX Operating 
System Technical Reference, published by IBM Corpo- 
ration, First Edition (November 1985), and other publi- 
cations. The skilled person would be aware of many oth- 
er suitable hardware/operating system/server combina- 
tions which may be used. 

Another possibility is that the Internet client may be 
a data processing system or a so-called "Web appli- 
ance" such as illustrated in FIGURES 2A-2D and 3. FIG- 
URE 2A is a pictorial representation of the data process- 
ing system as a whole. Data processing system 100 in 
the depicted example provides, with minimal economic 
costs for hardware to the user, access to the Internet. 
Data processing system 100 includes a data processing 
unit 102. Data processing unit 102 is preferably sized to 
fit in typical entertainment centers and provides all re- 
quired functionality, which is conventionally found in per- 
sonal computers, to enable a user to "browse" the Inter- 
net. Additionally, data processing unit 102 may provide 
other common functions such as serving as an answer- 
ing machine or receiving facsimile transmissions. 

Data processing unit 102 is connected to television 
104 for display of graphical information. Television 104 
may be any suitable television, although color televi- 
sions with an S-Video input will provide better presen- 
tations of the graphical information. Data processing 
unit 102 may be connected to television 104 through a 
standard coaxial cable connection. A remote control unit 
106 allows a user to interact with and control data 
processing unit 102. Remote control unit 106 emits in- 
frared (IR) signals, preferably modulated at a different 
frequency from the normal television, stereo, and VCR 
infrared remote control frequencies in order to avoid in- 
terference. Remote control unit 106 provides the func- 
tionality of a pointing device (such as a mouse, glide- 


point, trackball or the like) in conventional personal com- 
puters, including the ability to move a cursor on a display 
and to select items. 

FIGURE 2B is a pictorial representation of the front 

5 panel of data processing unit 102. The front panel in- . 
eludes an infrared window 108 for receiving signals from 
. remote control unit 1 06 and for transmitting infrared sig- 
nals. Data processing unit 1 02 may transmit infrared sig- 
nals to be reflected off objects or surfaces, allowing data 

10 processing unit 102 to automatically control television 
104 and other infrared remote controlled devices. Vol- 
ume control 110 permits adjustment of the sound level 
emanating from a speaker within data processing unit 
102 or from television 104. A plurality of light-emitting 

is diode (LED) indicators 112 provide an indication to the 
user of when data processing unit 102 is on, whether 
the user has messages, whether the modem/phone line 
is in use, or whether data processing unit 102 requires 
service. 

20 FIGURE 2C is a pictorial representation of the rear 
panel of data processing unit 102. A three wire (ground 
included) insulated power cord 114 passes through the 
rear panel. Standard telephone jacks 116 and 118 on 
the rear panel provide an input to a modem from the 

2S phone line and an output to a handset (not shown) . The 
real panel also provides a standard computer keyboard 
connection 120, mouse port 122, computer monitor port 
124, printer port 126, and an additional serial port 128. 
These connections may be employed to allow data 

30 processing unit 102 to operate in the manner of a con- 
ventional personal computer. Game port 1 30 on the rear 
panel provides a connection for a joystick or other gam- 
ing control device (glove, etc.). Infrared extension jack 
1 32 allows a cabled infrared LED to be utilized to trans- 

35 mit infrared signals. Microphone jack 1 34 allows an ex- 
ternal microphone to be connected to data processing 
unit 102, 

Video connection 136, a standard coaxial cable 
connector, connects to the video-in terminal of television 

40 104 or a video cassette recorder (not shown). Left and 
right audio jacks 1 38 connect to the corresponding au- 
dio-in connectors on television 104 or to a stereo (not 
shown) . If the user has S-Video input, then S-Video 
connection 140 may be used to connect to television 

45 104 to provide a better picture than the composite sig- 
nal. If television 104 has no video inputs, an external 
channel 3/4 modulator (not shown) may be connected 
in-line with the antenna connection. 

FIGURE 2D is a pictorial representation of remote 

50 control unit 106. Similartoastandardtelephone keypad, 
remote control unit 106 includes buttons 142 for Arabic 
numerals 0 through 9, the asterisk or "star" symbol (*), 
and the pound sign (#). Remote control unit also in- 
cludes "TV" button 1 44 for selectively viewing television 

55 broadcasts and "Web" button 146 for initiating "brows- 
ing 8 of the Internet. Pressing "Web" button 146 will 
cause data processing unit 102 to initiate modem dial- 
up of the user's Internet service provider and display the 
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start-up screen for an Internet browser. 

A pointing device 147, which is preferably a track- 
point or "button 0 pointing device, is included on remote 
control unit 106 and allows a user to manipulate a cursor 
1 on the display of television 104. "Go" and "Back" buttons s 
148 and 1 50, respectively, allow a user to select an op- 
tion or return to a previous selection. "Help" button 151 
causes context-sensitive help to be displayed or other- 
wise provided. "Menu" button 152 causes a context- 
sensitive menu of options to be displayed, and "Update" 10 
button 153 will update the options displayed based on 
the user's input, while home button 154 allows the user 
to return to a default display of options. "PgUp" and. 
"PgDn" buttons 156 and 158 allow the user to change 
the context of the display in display-sized blocks rather is 
than by scrolling. The message button 160 allows the 
user to retrieve messages. 

In addition to, or in lieu of, remote control unit 106, 
an infrared keyboard (not shown) with an integral point- 
ing device may be used to control data processing unit 20 
102. The integral pointing device is preferably a track- 
point or button type of pointing device. A wired keyboard 
(also not shown) may also be used through keyboard 
connection 120, and a wired pointing device such as a 
mouse or trackball may be used through mouse port 2s 
122. When a user has one or more of the remote control 
unit 106, infrared keyboard, wired keyboard and/or 
wired pointing device operable, the active device locks 
out all others until a prescribed period of inactivity has 
passed. 30 

Referring now to FIGURE 3, a block diagram for the 
major components of data processing unit 102 is por- 
trayed. As with conventional personal computers, data 
processing unit 102 includes a motherboard 202 con- 
taining a processor 204 and memory 206 connected to 35 
system bus 280. Processor 205 is preferably at least a 
486 class processor operating at or above 100 MHz. 
Memory 206 may include cache memory and/or video 
RAM. Processor 205, memory 206, and system bus 208 
operate in the same manner as corresponding compo- 40 
nents in a conventional data processing system. 

Video/TV converter 210, located on motherboard 
202 and connected to system bus 208, generates com* 
puter video signals for computer monitors,, a composite 
television signal, and an S-Video signal. The function- 45 
ality of Video/TV converter 210 may be achieved 
through a Trident TVG9685 video chip in conjunction 
with an Analog Devices AD722 converter chip. Video/ 
TV converter 210 may require loading of special oper- 
ating system device drivers. so 

Keyboard/remote control interface unit 212 on 
motherboard 202 receives keyboard codes through 
controller 214, regardless of whether a wired keyboard/ 
pointing device or an infrared keyboard/remote control 
is being employed. Infrared remote control unit 106 55 
transmits signals which are ultimately sent to the serial 
port as control signals generated by conventional 
mouse or pointing device movements. Two buttons on 


remote control unit 106 are interpreted identically to the 
twp buttons on a conventional mouse, while the remain- 
der of the buttons transmit signals corresponding to key- 
strokes on an infrared keyboard. Thus, remote control 
unit 106 has a subset of the function provided by an in- 
frared keyboard. 

Connectors/indicators 216 on motherboard 202 
provide some of the connections and indicators on data 
processing unit 102 described above. Other connec- 
tions are associated with and found on other compo- 
nents. For example, telephone jacks 116 and 118 are 
located on modem 222. The power indicator within con- 
nectors/indicators 216 is controlled by controller 214. 

External to motherboard 202 in the depicted exam- 
ple are power supply 218, hard drive 220, modem 222 
and speaker 224. Power supply 218 is a conventional 
power supply except that it receives a control signal from 
controller 214 which effects shut down of all power to 
motherboard 202, hard drive 220 and modem 222. In 
some recovery situations, removing power and reboot- 
ing is the only guaranteed method of resetting all of 
these devices to a known state. Th us, power supply 2 1 8, 
in response to a signal from controller 214, is capable 
of powering down and restarting data processing unit 
102. 

Controller 214 is preferably one or more of the 805x 
family controllers. Controller 214 receives and process- 
es input from infrared remote control 106, infrared key- 
board, wired keyboard, or wired mouse. When one key- 
board or pointing device is used, all others are locked 
out (ignored) until none has been active for a prescribed 
period. Then the first keyboard or pointing device to gen- 
erate activity locks out all others. Controller 21 4 also di- 
rectly controls all LED indicators except that indicating 
modem use. As part of the failure recovery system, con- 
troller 21 4 specifies the boot sector selection during any 
power off-on cycle. 

Hard drive 220 contains operating system and ap- 
plications software for data processing unit 102, which 
preferably includes IBM DOS 7.0 program, a product of 
International Business Machines Corporation in Ar- 
monk, New York; an operating system such as Windows 
3.1 (or higher), a product of Microsoft Corporation in 
Redmond, Washington; and Netscape Navigator (Ver- 
sion 1 .0 or higher), a product of Netscape Communica- 
tions Corporation in Mountain View, California. Hard 
drive 220 also supports a conventional FTP mechanism 
to facilitate file transfers from Internet FTP sites, all in a 
known manner. Other conventional Internet tools, in- 
cluding e-mail, bulletin board, and on-line chat capabil- 
ity, may also be provided. Of course, the software iden- 
tified above is merely representative, as other known 
programs may be used in the alternative or by way of 
addition. Also, minor modifications of these software 
packages may be desirable to optimize performance of 
data processing unit 102. 

Modem 222 may be any suitable modem used in 
conventional data processing systems, but is preferably 
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a 33.6 kbps modem supporting the V.42bis, V.34, V.17 
Fax, MNP 1-5, and AT command sets. To maintain the. 
slim height of data processing system 102, modem 222 
is preferably inserted into a slot mounted sideways on 
motherboard 202. Modem 222 is connected to a physi- 
cal communication link 227, which, in turn, in connected 
or connectable to the Internet (not shown). 

Those skilled in the art will recognize that the com- 
ponents depicted in FIGURES 2A-2D and 3 and de- 
scribed above may be varied for specific applications or 
embodiments. 

A file transfer program 225 run by the processor is 
used to administer and manage "updating" of the vari- 
ous application programs, preferably without interaction 
or intervention by a user of the appliance. This piece of 
code cooperates with a program located at a server to 
facilitate the file transfer download method of the 
present invention, and it is preferably designed to lie "on 
top" of a conventional FTP mechanism. An Internet cli- 
ent runs the client component of the download routine 
while an Internet server runs the server component of 
the program, and both of these components overlay the 
FTP mechanism to ensure backwards compatibility with 
existing approaches. 

The preferred protocol implemented by the client 
and server components is illustrated in the process flow 
diagram of FIGURE 4. Before discussing this operation 
in detail, reference should also be made to FIGURE 5, 
which illustrates a representative file "profile". Typically, 
each file desired to be transmitted is identified in a mas- 
ter list of files to be downloaded. Preferably, this master 
list is stored at the Internet server, and it may be acces- 
sible by the client. For each file to be downloaded, there 
is an associated "profile" that is generated. A represent- 
ative profile 250 for the file titled CONFIG.SYS.PRO is 
illustrated. The profile includes two primary sections, a 
header section 252 and a body section 254. Each sec- 
tion includes so-called identifying information useful in 
deconstructing and constructing the file. Header section 
252 includes an identifier CONFIG.SYS for the file and 
various attributes: a {date/time} attribute identifying a 
date and time when the profile was created, a {size} at- 
tribute indicating the size of the overall file (preferably 
in bytes), and a cyclic redundancy code {CRC} which 
acts as a checksum uniquely identifying the file. The 
{size} is preferably a 32-bit size of the file (unsigned 
long), and the CRC is a 32-bit CRC. As is known in the 
art, a CRC may be generated for a particular file (or com- 
ponent thereof) by generating a running count from the 
hexadecimal or other character strings that comprise 
the file. The CRC for the overall file is calculated and 
stored in the profile header section 252. Other check- 
sum approaches may be used in the alternative. 

The profile body section 254 includes identifying in- 
formation for a set of one or more components of the file 
that (in the preferred embodiment) must be combined 
or "reassembled" in order to make a working file. In this 
example, CONFIG.SYS.PRO is made up of three com- 


ponents: CONFIG, SYS1 , CONFIG.SYS2 and CONFIG. 
SYS3. In a representative embodiment, a component is 
of a fixed size (e.g., up to and including 75K bytes). Of 
course, this size designation is.merely exemplary. Each 
s component includes an identifier and a pair of attributes: 
{size} and associated {CRC}. These attributes are mere- 
ly representative as other functional characteristics may 
be used as well. Thus, for example, a security attribute 
may be included so that the client does not download a 
10 non-usable or bogus file. As noted above, the {size} at- 
tribute is preferably a 32-bit size of the file component 
(unsigned long), and the CRC is a 32-bit CRC calculated 
for each particular component. This identifying informa- 
tion is used by the client component to verify complete- 
rs ness of the transmission of any component. Preferably, 
all numeric fields are stored as hexadecimal character 
strings. 

In the preferred embodiment, the profile is generat- 
ed for each file to be downloaded. This process is pref- 

20 erably done "off-line" (i.e. not during a download ses- 
sion) to save time. The client and server, in effect, 
"agree" on the naming conventions for the profile by . 
having the server download the profile to the client that 
is expected to receive the file download. Although not 

25 illustrated in detail, it should be appreciated that the 
server includes an appropriate management and ad- 
ministrative interface (e.g., a DOS-based interface or a 
Windows-based graphical user interface with control 
menus and the like) for formatting each file into its com- 

30 ponents parts. Preferably, a user (which may be a sys- 
tem designer, an administrator, a person familar with 
protocols or some other third party) merely enters the 
size and naming conventions into appropriate dialog 
boxes and the profile (with the {CRC} and other header 

35 block information) is generated automatically. The serv- 
er code also breaks the file into its component parts, and 
these parts are preferably stored in addressable loca- 
tions. 

Assume now that CONFIG.SYS.PRO file is to be 

40 downloaded from the server (at which it is resident) to 
an Internet client and that the profile 250 is represented 
by x.pro. The file, for example, may be a new version of 
an application running on the Web appliance, and it is 
preferred that this download process be effected without 

45 the user's actual knowledge or interaction. The three 
pieces of CONFIG.SYS.PRO are identified as x.1, x.2 
and x.3 in the process flow diagram of FIGURE 4 and 
each of these file components preferably includes its 
own header in which the associated identfying informa- 

50 tion is included. 

The protocol begins with the client machine con- 
necting to the Internet, and it is preferred that this pro- 
tocol overlay a conventional FTP mechanism such that 
file components are transferred between server and cli- 

55 ent using FTP. A flow diagram showing the following 
process steps is illustrated in FIGURE 6. The process 
begins at step 260 in response to some control com- 
mand^) from the server indicating that a download ses- 
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sion involving the file is about to be initiated. In re- 
sponse, the client initiates a request tor the profile (x. 
pro) and transmits this request to the server. This is step 
262 in FIGURE 6. The server then sends back the profile 
x.pro, which is step 263 in FIGURE 6. As used herein, 
"initiating 0 a request preferably (but not by way of limi- 
tation) means an action by the client component of the 
download routine, not the user of the client machine. Up- 
on receipt of the profile, the client performs a test or 
check at step 264 in the flowchart to determine whether 
or not the existing parts or components of the file (as 
identified in the profile) are present at the client. Prefer- 
ably a "checklist" or the like is set up by the client com- 
ponent and evaluated for this purpose. Another possi- 
bility is that the client component may set up some type 
of data structure (or other list) to keep track of the profile 
components. If the outcome of this evaluation is nega- 
tive, the routine continues at step 266. At this point, the 
client requests a first component x.1 of the file (as iden- 
tified by the profile) and transmits this request to the 
server. At step 268 in the flowchart, the server responds 
by sending component x. 1 . 

Upon receipt of code purporting to be the first com- 
ponent x.1, the client component preferably compares 
the {size} and {CRC} information with the identifying in- 
formation in the profile and records whether the compo- 
nent has downloaded completely. This is step 270. The 
size and/or CRC comparison may be deferred until all 
of the pieces are received. The {size} is determined by 
counting the bytes and the {CRC} is calculated in the 
known manner. A test is then run at step 272 to deter- 
mine If the first component x.1 has been received in Its 
entirety (as indicated by the comparison with the profile). 
If the result of the test at step 272 is positive, the down- 
load sequence continues. In particular, a test is per- 
formed at step 274 to determine if all of the components 
have been received. If not, the routine cycles back and 
repeats for each of the remaining components. 

Preferably, the components are transferred from 
server to client in sequential order but this is not re- 
quired. The download sequence continues in this fash- 
ion (with each received component being checked 
against the profile identifying information), until all com- 
ponents have been requested by the client and trans- 
ferred by the server. 

When all components have been received, as indi- 
cated by a positive result of the test at step 274, the cli- 
ent component reassembles the components at step 
276 and then calculates the {size} and {CRC} for the 
overall file at step 278. A test is then made at step 280 
to determine whether the entire file is now present in the 
client. This is achieved by comparing the calculated in- 
formation with the identifying information in the profile 
header block. If the outcome of the test at step 280 is 
positive, the routine is complete. If the outcome is neg- 
ative, the routine returns to step 266 to obtain the miss- 
ing component(s). 

Assume now that the file transfer has been inter- 


rupted after the client requested component x.2. This is 
illustrated in the process flow diagram of FIGURE 4. A 
transmission interruption may be caused by any number 
of factors such as a power outage or the user inadvert- 

5 entfy or intentionally turning off the power to the Web 
appliance. In this circumstance, however, the client 
again connects to the Internet and requests transfer of 
the profile x.pro. The server responds by re-sending the 
profile, which is advantageous because the file may 

10 have changed while the client was disconnected. Re- 
sending the profile is not always required, however, be- 
cause there may be situations where the file state is per- 
sistent. In the preferred embodiment, however, the pro- 
file is retransmitted. The client then checks for the ex- 
's jsting parts as previously described. At this point in the 
example, component x.1 is found, but component x.2 is 
not found (or its size or CRC does not match the profile 
identifying information). Thus, the client requests com- 
ponent x.2, and the server responds by sending this 

20' component. After validation, the download sequence 
then continues with the client requesting the next com- 
ponent, x.3 and transmitting this request to the server. 
The server responds in due course by transferring com- 
ponent x.3. When all pieces of the file have been trans- 

25 ferred (and this is determined by analyzing the profile), 
the client reassembles the pieces, checks the CRC and 
the date/time stamp if needed, and the process ends. 

As can be seen, this approach is highly advanta- 
geous because it obviates retransmission of the entire 

30 file if any portion of the transmission is interrupted. Al- 
though the process flow of FIGURE 4 shows a single 
transmission interruption, the technique is useful re- 
gardless of the frequency of interruptions or the delay 
associated with any of them. Preferably, such file trans- 

35 fer takes place "transparently" to the user of the Web 
appliance, and thus software resident in the appliance 
can be periodically updated. This makes the appliance 
easy to use and maintain. Moreover, by overlaying the 
routine over a conventional FTP mechanism, the indi- 

40 vidual components of the file are transferred using the 
existing FTP, and thus the solution is backwards com- 
patible with existing applications. 

Another advantage of the above approach is that 
the file is broken into a number of components, which 

45 enables the transfer of multiple components simultane- 
ously. This can be achieved by opening multiple sockets 
between the client and the server during a session. 
Moreover, it should be appreciated that the technique 
described herein is most useful for files greater than 

50 about SOKbytes in size, and especially for files greater 
than 100Kbytes. 

The skilled person would also recognise many other 
possible modifications and variations. Thus, for exam- 
ple, a server may be provided with a mechanism that is 

55 responsive to a client request for breaking up a compos- 
ite file into components, creating a profile for the file, and 
then returning the profile to the client. The remainder of 
the file transfer would then proceed as described above. 
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transferred prior to the interruption is not re-trans- 
ferred from the server to the client. 

4. The method of any preceding Claim, wherein the 
5 network transmission protocol is the File Transfer 

Protocol (FTP). 

5. The method of any preceding Claim, wherein the 
identifying information in the profile for each com- 

10 ponent includes an identifier, a value indicating the 
size of the component, and a code uniquely identi- 
fying the component. 

6. The method of Claim 5, wherein the code is a cyclic 
is redundancy code. 

7. The method of any preceding Claim, further com- 
prising the step of verifying (270) that a component 
transferred to the client is part of the file using the 

20 identifying information. 


This can be accomplished with a new server daemon or 
by modifying an existing FTP daemon to accept a new 
FJP site command. A suitable application programming 
interface (API) may then be provided to facilitate third 
party use of the server mechanism. 

One of the preferred implementations of the file 
transfer scheme is as a set of instructions (program 
code) in a code module resident in the random access 
memory of the computer. Until required by the computer, 
the set of instructions may be. stored in another compu- 
ter memory, for example, in a hard disk drive, or in a 
removable memory such as an optical disk (for eventual 
use in a CD ROM) or floppy disk (for eventual use in a 
floppy disk drive), or downloaded via the Internet or oth- 
er computer network. In addition, although the various 
methods described are conveniently implemented in a 
general purpose computer selectively activated or 
reconfigured by software, one of ordinary skill in the art 
would also recognize that such methods may be carried 
out in hardware, in firmware, or in more specialized ap- 
paratus constructed to perform the required method 
steps. 

As used herein, "Internet client" and "Internet serv- 
er"should be regarded as including any computer, com- 
puter platform, or other suitable device directly or indi- 
rectly connected or connectable in any known or later- 
developed manner to the Internet or any other suitable 
network, with the "client" representing one who requests 
or gets the file, and "server" the entity which downloads 
the file. 

It should further be appreciated that technique de- 
scribed herein could also be used to cache data and pro- 
grams at a local server serving a set of Internet clients 
from a master server to conserve network resources. 


Claims 

1. A method of downloading a file comprising a set of 
components from a server (12) to a client (1 0) over 
a network (14), comprising the steps of: 

generating a profile of the file that includes 
identifying information for each component; 
initiating a download sequence by which each 
. component is transferred (268), one-by-one, 
from the server to the client using a network 
transmission protocol; 

when the download sequence is complete, re- 
assembling (276) the components into the file 
using the profile. 

2. The method of Claim 1 , further comprising the step 
of restarting the download sequence, following in- 
terruption of the download sequence, with a com- 
ponent affected by the interruption. 

3. The method of Claim 2, wherein any component 


8. The method of any preceding Claim, further com- 
prising the initial step of breaking the file into the set 
of components. 

25 

9. The method of any preceding Claim, further com-, 
prising the step of transferring (263) the profile from 
the server to the client prior to initiating the down- 
load sequence. 

30 

10. The method of Claim 9, wherein the profile includes 
identifying information for the file and each compo- 
nent thereof, said method further comprising the 
steps of: 

35 

using the identifying information upon receipt 
at the client of a component to verify whether a 
complete version of the component has been 
transferred; 

40 jf the complete version of the component has 

not been transferred, restarting the download 
sequence with the component; and 
when the download sequence is complete, ver- 
ifying (278, 280) whether a complete version of 

45 the file has been transferred using the identify- 

ing information for the file; 
if the complete version of the file has been 
transferred, reassembling the components into 
the file. 

50 

11. The method of Claim 10, further including the step 
of re-transferring the profile from the server to the 
client prior to restarting the download sequence. 

55 1 2. The method of Claim 1 0 or 1 1 , wherein the identify- 
ing information for the file includes a code uniquely 
identifying the file. 
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13. The method of Claim 12, wherein the code is a cy- 
clic redundancy code. 

14. The method of any preceding Claim wherein the 
components are transferred in a sequential order 
as determined by the profile. 

15. The method of any preceding Claim wherein the 
network is the Internet, and the client is a Web ap- 
pliance attached to the Internet. 

16. The method of Claim 1 5 wherein the file is a updat- 
ed version of a program running on the Web appli- 
ance. 

17. The method of claim 15 or 16 wherein the file is 
downloaded over the Internet to the Web appliance 
without requiring any specific action by a user. 

18. A computer program product for use in downloading 
a file, comprising a set of components, from a server 
to a client, the computer program product compris- 
ing: 

a computer-readable storage medium having 
a substrate; and a program encoded in the sub- 
strate of the computer-readable storage medium, 
wherein the program includes means for performing 
the method of any preceding claim. 

19. A client computer connectable to the Internet, com- 
prising: , . 

a processor; 
an operating system; 
Internet protocol means; and 
a client component of a file transfer download 
routine, the client component having an asso- 
ciated server component supported on a serv- 
er; wherein the client component of the file 
transfer download routine includes means re- 
sponsive to receipt of component pieces of a 
file for reassembling component pieces into the 
file using a file profile. 

20. A data processing system (100), comprising: 

a remote control unit (1 06); and 
a base unit (102) connectable to a monitor 
(104) for providing Internet access under the 
control of the remote control unit, the base unit 
comprising the client computer of Claim 19. 

21. A server computer connectable to the Internet, 
comprising: 

a processor; 

an operating system; 

Internet protocol means; and 


a server component of a file transfer download 
routine, the server component having an asso- 
ciated client component supported on a client 
machine; wherein the server component in- 

5 eludes means for initiating a download se- 

quence by which components of a file are trans- 
ferred, one-by-one, from the server computer 
to the client machine using the Internet protocol 
means, and means responsive to any interrup- 

10 tion of the download sequence for restarting the 

sequence with the component affected by the 
interruption. 

22. The computer of Claim 19 or 21 wherein the Internet 
15 protocol means is FTP. 
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(54) Method for file transfer 

(57) A method is provided of downloading a file from 
an Internet server 12 to an Internet client 10, preferably 
without action by the Internet client. The method begins 
by associating the file into a set of components at the 
server. A profile of the file is then generated. This profile 
includes identifying information for the file as well as for 
each component thereof. Such information preferably 
includes an identifier, a size value; and a code uniquely 
identifying the component The file is transferred by in- 


itiating a download sequence by which each component 
is transferred, one-by-one, from the server to the client 
using an Internet protocol. When the download se- 
quence is complete, the individual components are re- 
assembled into the file using the profile without action 
by the Internet client. If the transmission is interrupted 
for any reason, the download sequence is restarted with 
the component affected by the interruption. This avoids 
the need to retransfer the entire file. 
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Description 

The present invention relates generally to computer 
networks and more particularly to the efficient transfer 
of relatively large computer files over the Internet using 
standard Internet protocols. 

The Internet offers a suite of well-known services 
including one-to-one messaging (e-mail), one-to-many 
messaging (bulletin board), on-line chat, file transfer 
and browsing. Various known Internet protocols are 
used for these services. Thus, for example, browsing is 
effected using the Hypertext Transfer Protocol (HTTP), 
which provides users access to multimedia files using 
Hypertext Markup Language (HTML). The collection of 
servers that use HTTP comprise the World Wide Web, 
which is the Internet's multimedia information retrieval 
system. The File Transfer Protocol (FTP) is a mecha- 
nism for transferring files from a server to a client. Typ- 
ically, the client includes an FTP interface and appropri- 
ate software to control transfer and decompression of 
the received file. 

There has been great interest in providing Internet 
access at minimal economic cost. While most comput- 
ers now are pre-configured for Internet access, a signif- 
icant percentage of households still do not have a per- 
sonal computer. Thus, it has now been proposed to pro- 
vide a data processing system that, much like a VCR, 
may be connected to a television set and used in lieu of 
a personal computer to provide Web access through a 
conventional remote control device associated with the 
system unit. Such a system enables the television to be- 
come, in effect, a "Web" appliance. The viewer can rap- 
idly switch between conventional television and Internet 
access using the remote control unit. All of the conven- 
tional "Internet" access tools and navigational functions 
are preferably "built-in" to the system and thus hidden 
to the user. 

It would also be desirable to update software run- 
ning on the Web appliance without interaction or even 
the knowledge of the user. This goal, however, cannot 
be achieved reliably and cheaply because FTP and oth- 
er Internet protocols do not allow file transfer restarts. A 
file transfer "restart" means that the transfer is re-initiat- 
ed at a point of interruption. Thus, in the event that a 
conventional FTP file transmission were interrupted, e. 
g., due to a power outage or other such event, it is nec- 
essary to retransfer the entire file. This is highly imprac- 
tical with very large files across a typical 28.8Kbs mo- 
dem, especially without user interaction. 

Accordingly the present invention provides a meth- 
od of downloading a file comprising a set of components 
from a server to a client over a network, comprising the 
steps of: 

generating a profile of the file that includes identify- 
ing information for each component; 
initiating a download sequence by which each com- 
ponent is transferred, one-by-one, from the server 


to the client using a network transmission protocol; 
when the download sequence is complete, reas- 
sembling the components into the file using the pro- 
file. 

5 

In the preferred embodiment, the method further 
comprises the step of restarting the download se- 
quence, following interruption of the download se- 
quence, with a component affected by the interruption, 
10 wherein any component transferred prior to the interrup- 
tion is not re-transferred from the server to the client, 
thereby improving overall transmission efficiency. The 
network transmission protocol is preferably the File 
Transfer Protocol (FTP), but any other suitable existing 
15 or future protocol could be used. The identifying infor- 
mation in the profile for each component includes an 
identifier, a value indicating the size of the component, 
and a code uniquely identifying the component, with the 
code preferably being a cyclic redundancy code. This 
allows verification that a component transferred to the 
client is part of the file using the identifying information. 

Further in the preferred embodiment, there is an in- 
itial step of breaking the file into the set of components, 
followed by transferring the profile from the server to the 
client prior to initiating the download sequence. The pro- 
file includes identifying information for the file (prefera- 
bly including a code uniquely identifying the file) and 
each component thereof, and the method further com- 
prises the steps of: using the identifying information up- 
on receipt at the client of a component to verify whether 
a complete version of the component has been trans- 
ferred; if the complete version of the component has not 
been transferred, restarting the download sequence 
with the component; and when the download sequence 
is complete, verifying whether a complete version of the 
file has been transferred using the identifying informa- 
tion for the file; and if the complete version of the file has 
been transferred, reassembling the components into the 
file. Typically the profile will be re-transferred from the 
server to the client prior to restarting the download se- 
quence. It is preferred that the components are trans- 
ferred in a sequential order as determined by the profile, 
although this is not required, since they can be properly 
ordered at the client during the reassembly process. 

In one preferred embodiment, the network is the In- 
ternet, the client is a Web appliance attached to the In- 
ternet, and the file is a updated version of a program 
running on the Web appliance. Preferably the file is 
downloaded over the Internet to the Web appliance with- 
out requiring any specific action by a user (in other 
words, the file update occurs automatically, transparent- 
ly to the user). 

The invention further provides a computer program 
product for use in downloading a file, comprising a set 
of components, from a server to a client, the computer 
program product comprising: 

a computer-readable storage medium having a 
substrate; and a program encoded in the substrate of 


25 


30 


35 


40 


45 


50 


3 


EP 0 862 304 A2 


4 


the computer-readable storage medium, wherein the 
program includes means for performing the file down- 
load methods described above. 

The invention further provides a client computer 
connectabletothe Internet, comprising: a processor; an. 
operating system; Internet protocol means; and a client 
component of a file transfer download routine, the client 
component having an associated server component 
supported on a server; wherein the client component of 
the file transfer download routine includes means re- 
sponsive to receipt of component pieces of a file for re- 
assembling component pieces into the file using a file, 
profile. Such a client computer can be integrated for ex- 
ample as a base unit into a data processing system in- 
cluding a remote control unit and a monitor. 

In complementary fashion the invention further pro- 
vides a server computer connectable to the Internet, 
comprising: a processor; an operating system; Internet 
protocol means; and a server component of a file trans- 
fer download routine, the server component having an 
associated client component supported on a client ma- 
chine; wherein the server component includes means 
for initiating a download sequence by which compo- 
nents of afile are transferred, one-by-one, from the serv- 
er computer to the client machine using the Internet pro- 
tocol means, and means responsive to any interruption 
of the download sequence for restarting the sequence 
with the component affected by the interruption. 

Viewed from another aspect, the invention provides 
a computer program product for use in downloading a 
file, consisting of a set of components, from a Internet 
server to an Internet client, the computer program prod- 
uct comprising: 

a computer-readable storage medium having a sub- 
strate; and 

program data encoded in the substrate of the com- 
puter-readable storage medium, wherein the pro- 
gram data comprises: means for generating a pro- 
file that includes identifying information for the file 
and for each component thereof; means for initiat- 
ing a download sequence by which each compo- 
nent is transferred, one-by-one, from the server to 
the client using an Internet protocol; means respon- 
sive to any interruption of the download sequence, 
for restarting the download sequence with the com- 
ponent affected by the interruption; and means re- 
sponsive to completion of the download sequence 
for reassembling the components into the file using 
the profile. 

Viewed from a further aspect, the invention also pro- 
vides a computer program product for use in download- 
ing a file from a Internet server to an Internet client, the 
computer program product comprising: 

a computer-readable storage medium having a sub- 
strate; and 


program data encoded in the substrate of the com- 
puter-readable storage medium, wherein the pro- 
gram data comprises: means for breaking the file 
into a set of components; means for generating a 
s profile that includes identifying information for the 
file and for each component thereof; means for 
transferring the profile from the server to the client; 
means for initiating a download sequence accord- 
ing to the profile by which each component is trans- 
10 ferred, one-by-one, from the server to the client us- 
ing an Internet protocol; means responsive to any 
interruption of the download sequence for retrans- 
ferring the profile from the server to the client and 
restarting the download sequence with the compo- 
15 nent affected by the interruption; and means re- 
sponsive to completion of the download sequence 
for reassembling the components into the file using 
the retransferred profile. 

20 Viewed from a still further aspect, the invention also 
provides a method of downloading a file, consisting of 
a set of components, from a Internet server to an Inter- 
net client, comprising the steps of: 

25 generating a profile of the file that includes identify- 
ing information for each component; 
initiating a download sequence by which each com- 
ponent is transferred, one-by-one, from the server 
to the client using an Internet protocol; 
so when the download sequence is complete, reas- 
sembling the components into the file using the pro- 
file. 

Viewed from a still further aspect, the invention also 
35 provides a method of downloading a file, consisting of 
a set of components, from an Internet server to an In- 
ternet client, the file represented by a profile that in- 
cludes identifying information for the file and for each 
component thereof, comprising the steps of: 

40 

initiating a download sequence according to the 
profile by which each component is transferred, 
one-by-one, from the server to the client using the 
Internet File Transfer Protocol (FTP); 

45 upon receipt at the client of a component, using the 
identifying information to verify whether a complete 
version of the component has been transferred; 
if the complete version of the component has not 
been transferred, restarting the download se- 

50 quence with the component; and 

when the download sequence is complete, verifying 
whether a complete version of the file has been 
transferred using the identifying information for the 
file; 

55 if the complete version of the file has been trans- 
ferred, reassembling the components into the file. 

The file transfer mechanism of the invention allows 
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conventional FTP but at the same time allows for file 
transfer restarts. This effectively provides a checkpoint- 
able method for downloading files across the Internet or 
other suitable network. This therefore represents a 
method for downloading a file without a proprietary pro- s 
tocol but which still allows for file transfer restarts in the 
event of transmission interruption. One application of 
this mechanism is to update software running on a Web 
appliance transparently to the user by downloading a 
file from an Internet server to the appliance, thereby en- 
hancing the ease with which software is downloaded 
over the Internet. Such a file transfer download over the 
Internet would repeatedly transfer a discrete piece of a 
file as an atomic operation and then reassemble the dis- 
crete pieces at the client (preferably without direct user 
intervention). 

As described above, a file can be downloaded from 
an Internet server to an Internet client, preferably with- 
out interaction by a user of the Internet client, starting 
by breaking the file into a set of components. Then, a 
profile is generated for the file that includes identifying 
information for the file and for each component thereof. 
The identifying information may include an identifier, a 
size value, and a code uniquely identifying the file and/ 
or component thereof. To transfer the file, a download 
sequence is initiated by which each component is trans- 
ferred, one-by-one, from the server to the client. Prefer- 
ably, the transfer of each component is achieved using 
conventional Internet FTP. When the download se- 
quence is complete, the components are reassembled. 
If the download sequence were interrupted for any rea- 
son, it is restarted at the point of interruption, as opposed 
to requiring retransmission of previously -delivered com- 
ponents. Preferably, the components of the file are 
transferred in a sequential order as determined by the 
profile. 

Preferably, the file profile is transmitted from the 
server to the client prior to initiation and, if necessary, 
any restart(s) of the download sequence. The profile is 
then used to verify whether components received at the 
client are "complete." Thus, for example, upon receipt 
at the client of a component, the identifying information 
is used to verify whether a complete version of the com- 
ponent has been transferred from the server. Typically, 
this is accomplished by comparing the size of the com- 
ponent with the expected size (as determined by the 
size value in the profile) and by calculating the code and 
comparing it to the code in the profile. If the complete 
version of the component has not been transferred (as 
determined by one or both of these tests), the profile is 
resent and the download sequence is restarted, begin- 
ning with the component whose transmission was in- 
complete. When the server completes the download, 
the client-resident code verifies whether a complete ver- 
sion of the file has been transferred using the identifying 
information for the file. If the complete version of the file 
has been transferred, the components thereof are then 
reassembled into the file. 


In the preferred embodiment, the Internet client is 
a Web appliance and the file is a updated version of a 
program (e.g., a browser) running on the Web appli- 
ance. 

\farious embodiments of the invention will now be 
described in detail by way of example only with refer- 
ence to the following drawings: 

FIGURE 1 is a representative client-server system 
for communication over the I nternet; 
FIGURE 2A is pictorial representation of a data 
processing system unit connected to a conventional 
television set to form a "Web" appliance; 
FIGURE 2B is a pictorial representation of a front 
panel of the data processing system unit; 
FIGURE 2C is a pictorial representation of a rear 
panel of the data processing system unit; 
FIGURE 2D is a pictorial representation of a remote 
control unit associated with the data processing 
system unit; 

FIGURE 3 is a block diagram of the major compo- 
nents of the data processing system unit; 
FIGURE 4 is a process flow diagram of a preferred 
method for downloading a file from an Internet serv- 
er to an Internet client such as the Web appliance 
of FIGURE 2A; 

FIGURE 5 is a representative file "profile"; and 
FIGURE 6 is a flowchart of the preferred method. 

FIGURE 1 illustrates an Internet client machine 10 
connected to a server platform 12 via a communication 
channel 14. For illustrative purposes, channel 14 is the 
Internet, an Intranet or other known connection. In the 
case of the Internet, server platform 12 is one of a plu- 
rality of servers which are accessible by clients, one of 
which is illustrated by machine 10. A client machine typ- 
ically includes a suite of known Internet tools to access 
the servers of the network and thus obtain certain serv- 
ices. These services include one-to-one messaging (e- 
mail), one-to-many messaging (bulletin board), on-line 
chat, file transfer and browsing. Various known Internet 
protocols are used for these services. Thus, for exam- 
ple, browsing is effected using the Hypertext Transfer 
Protocol (HTTP), which provides users access to multi- 
media files using Hypertext Markup Language (HTML). 
The collection of servers that use HTTP comprise the 
World Wide Web, which is the Internet's multimedia in- 
formation retrieval system. The File Transfer Protocol 
(FTP) is a mechanism for transferring files from a server 
to a client. Typically, the client includes an FTP interface 
and associated code to facilitate the transfer and, if 
needed, decompression of the received file. Appropriate 
code is also resident on the server side of a particular 
connection (at a so-called "FTP site"). 

By way of example only, a client machine is a per- 
sonal computer such as a desktop or notebook compu- 
ter, e.g., an IBM or IBM-compatible machine running un- 
der the OS/2 operating system, an IBM ThinkPad ma- 
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chine, or some other Intel x86 or Pentium-based com- 
puter running Windows 3. 1 or greater operating system; 
a representative server platform 12 comprises an IBM 
RS/6000 computer 18 (a RISC-based workstation) run- 
ning the AIX operating system 20 (version 4. 1 or above) 
and a server program 22. (IBM; OS/2, Thinkpad, RS/ 
6000, and AIX are trademarks of IBM Corporation; Intel 
and Pentium are trademarks of Intel Corporation; Win- 
dows is a trademark of Microsoft Corporation). In a pre- 
ferred embodiment, the server program 22 supports 
FTP in a known manner, using FTP mechanism 23 and 
thus the server platform is an FTP site. FTP is a TCP/ 
IP protocol for file transfers. Information about the FTP 
protocol may be obtained from Request For Comment 
(RFC) 765 (Oct. 1985), which is incorporated herein by 
reference. The platform 12 also includes a graphical us- 
er interface (GUI) 24 for management and administra- 
tion. It may also include an application programming in- 
terface (API). The various models of the RS/6000 com- 
puters are described in many publications of the IBM 
Corporation, for example, RISC System/6000, 701 3 and 
7016 POWERstation and POWERserver Hardware 
Technical Reference, Order No ; SA23-2644-00, whilst 
the AIX operating system is described in AIX Operating 
System Technical Reference, published by IBM Corpo- 
ration, First Edition (November 1985), and other publi- 
cations. The skilled person would be aware of many oth- 
er suitable hardware/operating system/server combina- 
tions which may be used. 

Another possibility is that the Internet client may be 
a data processing system or a so-called "Web appli- 
ance" such as illustrated in FIGURES 2A-2D and 3. FIG- 
URE 2A is a pictorial representation of the data process- 
ing system as a whole. Data processing system 100 in 
the depicted example provides, with minimal economic 
costs for hardware to the user, access to the Internet. 
Data processing system 100 includes a data processing 
unit 102. Data processing unit 102 is preferably sized to 
fit in typical entertainment centers and provides all re- 
quired functionality, which is conventionally found in per- 
sonal computers, to enable a user to "browse" the Inter- 
net. Additionally, data processing unit 102 may provide 
other common functions such as serving as an answer- 
ing machine or receiving facsimile transmissions. 

Data processing unit 1 02 is connected to television 
104 for display of graphical information. Television 104 
may be any suitable television, although color televi- 
sions with an S-Video input will provide better presen- 
tations of the graphical information. Data processing 
unit 102 may be connected to television 104 through a 
standard coaxial cable connection. A remote control unit 
106 allows a user to interact with and control data 
processing unit 102. Remote control unit 106 emits in- 
frared (IR) signals, preferably modulated at a different 
frequency from the normal television, stereo, and VCR 
infrared remote control frequencies in order to avoid in- 
terference. Remote control unit 106 provides the func- 
tionality of a pointing device (such as a mouse, glide- 


point, trackball or the like) in conventional personal conrh 
puters, including the ability to move a cursor on a display 
and to select items. 

FIGURE 2B is a pictorial representation of the front 

s panel of data processing unit 102. The front panel in- 
cludes an infrared window 1 08 for receiving signals from 
remote control unit 106 and for transmitting infrared sig- 
nals. Data processing unit 1 02 may transmit infrared sig- 
nals to be reflected off objects or surfaces, allowing data 

10 processing unit 102 to automatically control television 
104 and other infrared remote controlled devices. Vol- 
ume control 110 permits adjustment of the sound level 
emanating from a speaker within data processing unit 
102 or from television 104. A plurality of light -emitting 

is diode (LED) indicators 112 provide an indication to the 
user of when data processing unit 102 is on, whether 
the user has messages, whether the modem/phone line 
is in use, or whether data processing unit 102 requires 
service. 

20 FIGURE 2C is a pictorial representation of the rear 
panel of data processing unit 102. A three wire (ground 
included) insulated power cord 114 passes through the 
rear panel. Standard telephone jacks 116 and 118 on 
the rear panel provide an input to a modem from the 

25 phone line and an output to a handset (not shown) . The 
real panel also provides a standard computer keyboard 
connection 1 20, mouse port 1 22, computer monitor port 
124, printer port 126, and an additional serial port 128. 
These connections may be employed to allow data 

30 processing unit 102 to operate in the manner of a con- 
ventional personal computer. Game port 1 30 on the rear 
panel provides a connection for a joystick or other gam- 
ing control device (glove, etc.). Infrared extension jack 
1 32 allows a cabled infrared LED to be utilized to trans- 

35 m\\ infrared signals. Microphone jack 1 34 allows an ex- 
ternal microphone to be connected to data processing 
unit 102. 

Video connection 136, a standard coaxial cable 
connector, connects to the video-in terminal of television 

40 1 04 or a video cassette recorder (not shown). Left and 
right audio jacks 138 connect to the corresponding au- 
dio-in connectors on television 104 or to a stereo (not 
shown) . If the user has S-Video input, then S-Video 
connection 140 may be used to connect to television 

45 104 to provide a better picture than the composite sig- 
nal. If television 104 has no video inputs, an external 
channel 3/4 modulator (not shown) may be connected 
in-line with the antenna connection. 

FIGURE 2D is a pictorial representation of remote 

50 control unit 106. Similartoastandardtelephone keypad, 
remote control unit 106 includes buttons 142 for Arabic 
numerals 0 through 9, the asterisk or "star" symbol (*), 
and the pound sign (#). Remote control unit also in- 
cludes "TV" button 1 44 for selectively viewing television 

55 broadcasts and "Web" button 146 for initiating "brows- 
ing" of the Internet. Pressing "Web" button 146 will 
cause data processing unit 102 to initiate modem dial- 
up of the user's Internet service provider and display the 
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start-up screen for an Internet browser. 

A pointing device 147, which is preferably a track- 
point or "button" pointing device, is included on remote 
control unit 106 and allows a userto manipulate a cursor 
on the display of television 104. "Go 0 and "Back" buttons 
1 48 and 1 50, respectively, allow a user to select an op- 
tion or return to a previous selection. "Help" button 151 
causes context-sensitive help to be displayed or other- 
wise provided. "Menu" button 152 causes a context- 
sensitive menu of options to be displayed, and "Update" 
button 153' will update the options displayed based on 
the user's input, while home button 154 allows the user 
to return to a default display of options. "PgUp" and 
"PgDn" buttons 156 and 158 allow the user to change 
the context of the display in display-sized blocks rather 
than by scrolling. The message button 160 allows the 
user to retrieve messages. 

In addition to, or in lieu of, remote control unit 106, 
an infrared keyboard (not shown) with an integral point- 
ing device may be used to control data processing unit 
102. The integral pointing device is preferably a track- 
point or button type of pointing device. A wired keyboard 
(also not shown) may also be used through keyboard 
connection 120, and a wired pointing device such as a 
mouse or trackball may be used through mouse port 
1 22. When a user has one or more of the remote control 
unit 106, infrared keyboard, wired keyboard and/or 
wired pointing device operable, the active device locks 
out all others until a prescribed period of inactivity has 
passed. 

Referring now to FIGURE 3, a block diagram for the 
major components of data processing unit 102 is por- 
trayed. As with conventional personal computers, data 
processing unit 102 includes a motherboard 202 con- 
taining a processor 204 and memory 206 connected to 
system bus 280. Processor 205 is preferably at least a 
486 class processor operating at or above 100 MHz. 
Memory 206 may include cache memory and/or video 
RAM. Processor 205, memory 206, and system bus 208 
operate in the same manner as corresponding compo- 
nents in a conventional data processing system. 

Video/TV converter 210, located on motherboard 
202 and connected to system bus 208, generates com- 
puter video signals for computer monitors, a composite 
television signal, and an S-Video signal. The function- 
ality of Video/TV converter 210 may be achieved 
through a Trident TVG9685 video chip in conjunction 
with an Analog Devices AD722 converter chip. Video/ 
TV converter 210 may require loading of special oper- 
ating system device drivers. 

Keyboard/remote control interface unit 212 on 
motherboard 202 receives keyboard codes through 
controller 214, regardless of whether a wired keyboard/ 
pointing device or an infrared keyboard/remote control 
is being employed. Infrared remote control unit 106 
transmits signals which are ultimately sent to the serial 
port as control signals generated by conventional 
mouse or pointing device movements. Two buttons on 


remote control unit 106 are interpreted identically to the 
two buttons on a conventional mouse, wh ile the remain- 
der of the buttons transmit signals corresponding to key- 
strokes on an infrared keyboard. Thus, remote control 
s unit 106 has a subset of the function provided by an in- 
frared keyboard. 

Connectors/indicators 216 on motherboard 202 
provide some of the connections and indicators on data 
processing unit 102 described above. Other connec- 
ts tions are associated with and found on other compo- 
nents. For example, telephone jacks 116 and 118 are 
- located on modem 222. The power indicator within con- 
nectors/indicators 216 is controlled by controller 214. 
External to motherboard 202 in the depicted exam- 
's pie are power supply 218, hard drive 220, modem 222 
and speaker 224. Power supply 218 is a conventional 
power supply except that it receives a control signal from 
controller 214 which effects shut down of all power to 
motherboard 202, hard drive 220 and modem 222. In 
20 some recovery situations, removing power and reboot- 
ing is the only guaranteed method of resetting all of 
these devices to a known state. Thus, power supply 2 1 8, 
in response to a signal from controller 214, is capable 
of powering down and restarting data processing unit 
25 1 02. 

Controller 21 4 is preferably one or more of the 805x 
family controllers. Controller 214 receives and process- 
es input from infrared remote control 106, infrared key- 
board, wired keyboard, or wired mouse. When one key- 
so board or pointing device is used, all others are locked 
out (ignored) until none has been active for a prescribed 
period. Then the first keyboard or pointing device to gen- 
erate activity locks out all others. Controller 214 also di- 
rectly controls all LED indicators except that indicating 
35 modem use. As part of the failure recovery system, con- 
troller 214 specifies the boot sector selection during any 
power off -on cycle. 

Hard drive 220 contains operating system and ap- 
plications software for data processing unit 102, which 
40 preferably includes IBM DOS 7.0 program, a product of 
International Business Machines Corporation in Ar- 
monk, New York; an operating system such as Windows 
3.1 (or higher), a product of Microsoft Corporation in 
Redmond, Washington; and Netscape Navigator (Ver- 
^5 sion 1 .0 or higher), a product of Netscape Communica- 
tions Corporation in Mountain View, California. Hard 
drive 220 also supports a conventional FTP mechanism 
to facilitate file transfers from Internet FTP sites, all in a 
known manner. Other conventional Internet tools, in- 
50 eluding e-mail, bulletin board, and on-line chat capabil- 
ity, may also be provided. Of course, the software iden- 
tified above is merely representative, as other known 
programs may be used in the alternative or by way of 
addition. Also, minor modifications of these software 
55 packages may be desirable to optimize performance of 
data processing unit 102. 

Modem 222 may be any suitable modem used in 
conventional data processing systems, but is preferably 
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a 33.6 kbps modem supporting the V.42bis, V34, V.17 
Fax, MNP 1-5, and AT command sets. To maintain the 
slim height of data processing system 102, modem 222 
is preferably inserted into a slot mounted sideways on 
motherboard 202. Modem 222 is connected to a physi- 
cal communication link 227, which, in turn, in connected 
or connectable to the Internet (not shown). 

Those skilled in the art will recognize that the com- 
ponents depicted in FIGURES 2A-2D and 3 and de- 
scribed above may be varied for specific applications or 
embodiments. 

A file transfer program 225 run by the processor is 
used to administer and manage "updating" of the vari- 
ous application programs, preferably without interaction 
or intervention by a user of the appliance. This piece of 
code cooperates with a program located at a server to 
facilitate the file transfer download method of the 
present invention, and it is preferably designed to lie "on 
top" of a conventional FTP mechanism. An Internet cli- 
ent runs the client component of the download routine 
while an Internet server runs the server component of 
the program, and both of these components overlay the 
FTP mechanism to ensure backwards compatibility with 
existing approaches. 

The preferred protocol implemented by the client 
and server components is illustrated in the process flow 
diagram of FIGURE 4. Before discussing this operation 
in detail, reference should also be made to FIGURE 5, 
which illustrates a representative file "profile 0 . Typically, 
each file desired to be transmitted is identified in a mas- 
ter list of files to be downloaded. Preferably, this master 
list is stored at the Internet server, and it may be acces- 
sible by the client. For each file to be downloaded, there 
is an associated "profile" that is generated. A represent- 
ative profile 250 for the file titled CONFIG.SYS. PRO is 
illustrated. The profile includes two primary sections, a 
header section 252 and a body section 254. Each sec- 
tion includes so-called identifying information useful in 
deconstructing and constructing the file. Header section 
252 includes an identifier CONFIG.SYS for the file and 
various attributes: a {date/time} attribute identifying a 
date and time when the profile was created, a {size} at- 
tribute indicating the size of the overall file (preferably 
in bytes), and a cyclic redundancy code {CRC} which 
acts as a checksum uniquely identifying the file. The 
{size} is preferably a 32-bit size of the file (unsigned 
long), and the CRC is a 32-bit CRC. As is known in the 
art, a CRC may be generated for a particular file (or com- 
ponent thereof) by generating a running count from the 
hexadecimal or other character strings that comprise 
the file. The CRC for the overall file is calculated and 
stored in the profile header section 252. Other check- 
sum approaches may be used in the alternative. 

The profile body section 254 includes identifying in- 
formation for a set of one or more components of the file 
that (in the preferred embodiment) must be combined 
or "reassembled" in order to make a working file. In this 
example, CONFIG.SYS. PRO is made up of three com- 


ponents: CONFIG.SYS1, CONFIG. SYS2 and CONFIG. 
SYS3. In a representative embodiment, a component is 
of a fixed size (e.g., up to and including 75K bytes). Of 
course, this size designation is merely exemplary. Each 

s component includes an identifier and a pair of attributes: 
{size} and associated {CRC}. These attributes are mere- 
ly representative as other functional characteristics may 
be used as well. Thus, for example, a security attribute 
may be included so that the client does not download a 

10 non-usable or bogus file. As noted above, the {size} at- 
tribute is preferably a 32-bit size of the file component 
(unsigned long), and the CRC is a 32-bit CRC calculated 
for each particular component. This identifying informa- 
tion is used by the client component to verify complete- 

15 ness of the transmission of any component. Preferably, 
all numeric fields are stored as hexadecimal character 
strings. 

In the preferred embodiment, the profile is generat- 
ed for each file to be downloaded. This process is pref- 

20 erably done "off-line" (i.e. not during a download ses- 
sion) to save time. The client and server, in effect, 
"agree" on the naming conventions for the profile by 
having the server download the profile to the client that 
is' expected to receive the file download. Although not 

25 illustrated in detail, it should be appreciated that the 
server includes an appropriate management and ad- . 
ministrative interface (e.g., a DOS-based interface or a 
Windows-based graphical user interface with control 
menus and the like) for formatting each file into its com- 

30 ponents parts. Preferably, a user (which may be a sys- 
tem designer, an administrator, a person familar with 
protocols or some other third party) merely enters the 
size and naming conventions into appropriate dialog 
boxes and the profile (with the {CRC} and other header 

35 block information) is generated automatically. The serv- 
er code also breaks the file into its component parts, and 
these parts are preferably stored in addressable loca- 
tions. 

Assume now that CONFIG.SYS.PRO file is to be 

40 downloaded from the server (at which it is resident) to 
an Internet client and that the profile 250 is represented 
by x.pro. The file, for example, may be a new version of 
an application running on the Web appliance, and it is 
preferred that this download process be effected without 

45 the user's actual knowledge or interaction. The three 
pieces of CONFIG.SYS.PRO are identified as x.1, x.2 
and x.3 in the process flow diagram of FIGURE 4 and 
each of these file components preferably includes its 
own header in which the associated identfying informa- 

50 tion is included. 

The protocol begins with the client machine con- 
necting to the Internet, and it is preferred that this pro- 
tocol overlay a conventional FTP mechanism such that 
file components are transferred between server and cli- 

55 ent using FTP. A flow diagram showing the following 
process steps is illustrated in FIGURE 6. The process 
begins at step 260 in response to some control com- 
mand^) from the server indicating that a download ses- 
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sion involving the file is about to be initiated. In re- 
sponse, the client initiates a request for the profile (x. 
pro) and transmits this request to the server. This is step 
262 in FIGURE 6. The server then sends back the profile 
x.pro, which is step 263 in FIGURE 6. As used herein, 5 
"initiating" a request preferably (but not by way of limi- 
tation) means an action by the client component of the 
download routine, not the user of the client machine. Up- 
on receipt of the profile, the client performs a test or 
check at step 264 in the flowchart to determine whether 10 
or not the existing parts or components of the file (as 
identified in the profile) are present at the client. Prefer- 
ably a "checklist" or the like is set up by the client com- 
ponent and evaluated for this purpose. Another possi- 
bility is that the client component may set up some type is 
of data structure (or other list) to keep track of the profile 
components. If the outcome of this evaluation is nega- 
tive, the routine continues at step 266. At this point, the 
client requests a first component x.1 of the file (as iden- 
tified by the profile) and transmits this request to the 20 
server. At step 268 in the flowchart, the server responds 
by sending component x. 1 . 

Upon receipt of code purporting to be the first com- 
ponent x.1, the client component preferably compares 
the {size} and {CRC} information with the identifying in- 25 
formation in the profile and records whether the compo- 
nent has downloaded completely. This is step 270. The 
size and/or CRC comparison may be deferred until all 
of the pieces are received. The {size} is determined by 
counting the bytes and the {CRC} is calculated in the 30 
known manner A test is then run at step 272 to deter- 
mine If the first component x.1 has been received in Its 
entirety (as indicated by the comparison with the profile). 
If the result of the test at step 272 is positive, the down- 
load sequence continues. In particular, a test is per- 35 
formed at step 274 to determine if all of the components 
have been received. If not, the routine cycles back and 
repeats for each of the remaining components. 

Preferably, the components are transferred from 
server to client in sequential order but this is not re- 40 
quired. The download sequence continues in this fash- 
ion (with each received component being checked 
against the profile identifying information), until all com- 
ponents have been requested by the client and trans- 
ferred by the server. 45 

When all components have been received, as indi- 
cated by a positive result of the test at step 274, the cli- 
ent component reassembles the components at step 
276 and then calculates the {size} and {CRC} for the 
overall file at step 278. A test is then made at step 280 so 
to determine whether the entire file is now present in the 
client. This is achieved by comparing the calculated in- 
formation with the identifying information in the profile 
header block. If the outcome of the test at step 280 is 
positive, the routine is complete. If the outcome is neg- S5 
ative, the routine returns to step 266 to obtain the miss- 
ing component(s). 

Assume now that the file transfer has been inter- 


rupted after the client requested component x.2. This is 
illustrated in the process flow diagram of FIGURE 4. A 
transmission interruption may be caused by any number 
of factors such as a power outage or the user inadvert- 
ently or intentionally turning off the power to the Web 
appliance. In this circumstance, however, the client 
again connects to the Internet and requests transfer of 
the profile x.pro. The server responds by re-sending the 
profile, which is advantageous because the file may 
have changed while the client was disconnected. Re- 
sending the profile is not always required, however, be- 
cause there may be situations where the file state is per- 
sistent. In the preferred embodiment, however, the pro- 
file is retransmitted. The client then checks for the ex- 
isting parts as previously described. At this point in the 
example, component x. 1 is found, but component x.2 is 
not found (or its size or CRC does not match the profile 
identifying information). Thus, the client requests com- 
ponent x.2, and the server responds by sending this 
component. After validation, the download sequence 
then continues with the client requesting the next com- 
ponent, x.3 and transmitting this request to the server. 
The server responds in due course by transferring com- 
ponent x.3. When all pieces of the file have been trans- 
ferred (and this is determined by analyzing the profile), 
the client reassembles the pieces, checks the CRC and 
the date/time stamp if needed, and the process ends. 

As can be seen, this approach is highly advanta- 
geous because it obviates retransmission of the entire 
file if any portion of the transmission is interrupted. Al- 
though the process flow of FIGURE 4 shows a single 
transmission interruption, the technique is useful re- 
gardless of the frequency of interruptions or the delay 
associated with any of them. Preferably, such file trans- 
fer takes place "transparently" to the user of the Web 
appliance, and thus software resident in the appliance 
can be periodically updated. This makes the appliance 
easy to use and maintain. Moreover, by overlaying the 
routine over a conventional FTP mechanism, the indi- 
vidual components of the file are transferred using the 
existing FTP, and thus the solution is backwards com- 
patible with existing applications. 

Another advantage of the above approach is that 
the file is broken into a number of components, which 
enables the transfer of multiple components simultane- 
ously. This can be achieved by opening multiple sockets 
between the client and the server during a session. 
Moreover, it should be appreciated that the technique 
described herein is most useful for files greater than 
about SOKbytes in size, and especially for files greater 
than 100Kbytes. 

The skilled person would also recognise many other 
possible modifications and variations. Thus, for exam- 
ple, a server may be provided with a mechanism that is 
responsive to a client request for breaking up a compos- 
ite file into components, creating a profile for the file, and 
then returning the profile to the client. The remainder of 
the file transfer would then proceed as described above. 
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This can be accomplished with a new server daemon or 
by modifying an existing FTP daemon to accept a new 
FTP site command. A suitable application programming 
. interface (API) may then be provided to facilitate third 
party use of the server mechanism. 

One of the preferred implementations of the file 
transfer scheme is as a set of instructions (program 
code) in a code module resident in the random access 
memory of the computer. Until required by the computer, 
the set of instructions may be stored in another compu- 
ter memory, for example, in a hard disk drive, or in a 
removable memory such as an optical disk (for eventual 
use in a CD ROM) or floppy disk, (for eventual use in a 
floppy disk drive), or downloaded via the Internet or oth- 
er computer network. In addition, although the various 
methods described are conveniently implemented in a 
general purpose computer selectively activated or 
reconfigured by software, one of ordinary skill in the art 
would also recognize that such methods may be carried 
out in hardware, in firmware, or in more specialized ap- 
paratus constructed to perform the required method 
steps. 

As used herein, "Internet client" and "Internet serv- 
er'should be regarded as including any computer, com- 
puter platform, or other suitable device directly or indi- 
rectly connected or connectable in any known or later- 
developed manner to the Internet or any other suitable 
network, with the "client 0 representing one who requests 
or gets the file, and "server" the entity which downloads 
the file. 

It should further be appreciated that technique de- 
scribed herein could also be used to cache data and pro- 
grams at a local server serving a set of Internet clients 
from a master server to conserve network resources. 


Claims 

1 . A method of downloading a file comprising a set of 
components from a server (12) to a client (10) over 
a network (14), comprising the steps of: 

generating a profile of the file that includes 
identifying information for each component; 
initiating a download sequence by which each 
component is transferred (268), one-by-one, 
from the server to the client using a network 
transmission protocol; 

when the download sequence is complete, re- 
assembling (276) the components into the file 
using the profile. 

2. The method of Claim 1 , further comprising the step 
of restarting the download sequence, following in- 
terruption of the download sequence, with a com- 
ponent affected by the interruption. 

3. The method of Claim 2, wherein any component 


transferred prior to the interruption is not re-trans- 
ferred from the server to the client. 

4. The method of any preceding Claim, wherein the 
network transmission protocol is the File Transfer 
Protocol (FTP). 

5. The method of any preceding Claim, wherein the 
identifying information in the profile for each com- 
ponent includes an identifier, a value indicating the 
size of the component, and a code uniquely identi- 
fying the component. 

The method of Claim 5, wherein the code is a cyclic 
redundancy code. 

7. The method of any preceding Claim, further com- 
prising the step of verifying (270) that a component 
transferred to the client is part of the file using the 
identifying information. 

8. The method of any preceding Claim, further com- 
prising the initial step of breaking the file into the set 
of components. 

9. The method of any preceding Claim, further com- 
prising the step of transferring (263) the profile from 
the serverto the client prior to initiating the down- 
load sequence. 

10. The method of Claim 9, wherein the profile includes 
identifying information for the file and each compo- 
nent thereof, said method further comprising the 
steps of: 

using the identifying information upon receipt 
at the client of a component to verify whether a 
complete version of the component has been 
transferred; 

if the complete version of the component has 
not been transferred, restarting the download 
sequence with the component; and 
when the download sequence is complete, ver- 
ifying (278, 280) whether a complete version of 
the file has been transferred using the identify- 
ing information for the file; 
if the complete version of the file has been 
transferred, reassembling the components into 
the file. 

11. The method of Claim 10, further including the step 
of re-transferring the profile from the server to the 
client prior to restarting the download sequence. 

1 2. The method of Claim 1 0 or 1 1 , wherein the identify- 
ing information for the file includes a code uniquely 
identifying the file. 
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13. The method of Claim 12, wherein the code is a cy- 
clic redundancy code. 

14. The method of any preceding Claim wherein the 
components are transferred in a sequential order 
as determined by the profile. 

15. The method of any preceding Claim wherein the 
network is the Internet, and the client is a Web ap- 
pliance attached to the Internet. 

16. The method of Claim 15 wherein the file is a updat- 
ed version of a program running on the Web appli- 
ance. 

17. The method of claim 15 or 16 wherein the file is 
downloaded over the Internet to the Web appliance 
without requiring any specific action by a user. 

18. Acomputer program product for use in downloading 
a file, comprising a set of components, from a server 
to a client, the computer program product compris- 
ing: 

a computer-readable storage medium having 
a substrate; and a program encoded in the sub- 
strate of the computer-readable storage medium, 
wherein the program includes means for performing 
the method of any preceding claim. 

19. A client computer connectable to the Internet, com- 
prising: 

a processor; 
an operating system; 
Internet protocol means; and 
a client component of a file transfer download 
routine, the client component having an asso- 
ciated server component supported on a serv- 
er; wherein the client component of the file 
transfer download routine includes means re- 
sponsive to receipt of component pieces of a 
file for reassembling component pieces into the 
file using a file profile. 

20. A data processing system (100), comprising: 

a remote control unit (106); and 
a base unit (102) connectable to a monitor 
(104) for providing Internet access under the 
control of the remote control unit, the base unit 
comprising the client computer of Claim 1 9. 

21. A server computer connectable to the Internet, 
comprising: 

a processor; 

an operating system; 

Internet protocol means; and 


a server component of a file transfer download 
routine, the server component having an asso- 
ciated client component supported on a client 
machine; wherein the server component in- 

5 eludes means for initiating a download se- 

quence by wh ich components of a file are trans- 
ferred, one -by-one, from the server computer 
to the client machine using the Internet protocol 
means, and means responsive to any interrup- 

*0 tion of the download sequence for restarting the 

sequence with the component affected by the 
interruption. 

22. The computer of Claim 19 or 21 wherein the Internet 
15 protocol means is FTP 
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Profile: 


Contents Of C0NFI6.SYS.PR0: 


C CONFIG.SYS {Dote/Time} {Size} jCRCj-^252 
S CONFIG.SYS. 1 |Sizej jCRCj | 
S C0NFIG.SYS.2 jsizej |CRC| j-254 
S CONFIG.SYS.^ JSizej {CRC} J 


Dote\Time - DOS Time t Formot (Unsigned Long) 
Size - 32-Bit Size Of The File (Unsigned Long) 
CRC - 32-Bit CRC 


NOTE: All Numeric Fields Are Stored As Hex Chor Strings 
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